package leetcode;

/**
 * 写一个函数，求两个整数之和，要求在函数体内不得使用 “+”、“-”、“*”、“/” 四则运算符号。
 */
public class T65 {

    public int add(int a, int b) {
        while(b != 0) { // 当进位为 0 时跳出
            int c = (a & b) << 1;  // c = 进位   当位置上都为1时产生进位，然后向左移动一位
            a ^= b; // a = 非进位和               当位置上数不同时，保留数，相同的话 都为1 的话会产生进位，上面的已经算了进位值，都为0的话不做处理  此时a为 a+b 的不包含进位的值，后续递归将 a与进位的值相加
            b = c; // b = 进位
        }
        return a;
    }
}
